草庐IT

SQLite 事务(Transaction)

全部标签

Android SQLite 数据库 : slow insertion

我需要解析一个相当大的XML文件(在大约一百KB和几百KB之间变化),我正在使用Xml#parse(String,ContentHandler)进行解析。我目前正在使用一个152KB的文件对此进行测试。在解析期间,我还使用类似于以下的调用将数据插入到SQLite数据库中:getWritableDatabase().insert(TABLE_NAME,"_id",values)。对于152KB的测试文件(归结为插入大约200行),所有这些加起来大约需要80秒。当我注释掉所有插入语句(但保留其他一切,例如创建ContentValues等)时,同一个文件只需要23秒。数据库操作有这么大的开销

database - 使用 Golang 检索 SQLite Pragma user_version

这是我使用SQLite的第一个项目,在尝试进行半自动模式迁移时,我想使用stackoverflow上许多其他答案所建议的user_versionpragma。我正尝试在Golang中执行此操作,但不确定我是否应该使用Exec、Query或类似的东西来获得此结果,然后如何将其呈现为可用的东西。在sqlite3中我可以运行'PRAGMAuser_version;'它将返回3或我设置的任何值。 最佳答案 当您使用PRAGMAuser_version读取值时,此语句的行为与查询完全相同,即SELECTuser_versionFROMsome

Golang 事务退出处理

我有一个大约每秒100个请求的系统。有时直到我重新启动我的go程序它才会响应。我发现这是因为我在某些地方打开交易并没有关闭它。这就是为什么所有连接都被打开的事务占用而我无法打开另一个连接在此之后我添加了这段代码deferfunc(){ifr:=recover();r!=nil{tx.Rollback()return}iferr==nil{err=tx.Commit()}else{tx.Rollback()}}()这使我的程序可以连续运行一个月。可就在刚才,它又发生了。大概是因为这个问题。有没有更好的方法来关闭交易?或者如果交易打开1分钟就可以关闭交易? 最佳

sqlite - 使用 Golang 的 SQLite3

今天,gogland下载新更新,获取更新后,显示如下错误信息。以前它工作正常。请建议解决问题。GOROOT=/usr/local/goGOPATH=/home/minhaj/GoLang/usr/local/go/bin/gobuild-o/home/minhaj/GoLang/bin/GoLangRun-gcflags"-N-l""-ldflags=-linkmodeinternal"/home/minhaj/GoLang/src/IndoorMass/IndoorMain.go命令行参数github.com/mattn/go-sqlite3(.data.rel):unexpecte

go - 使用 go 从我的 sqlite 数据库中获取最后一条记录

我想查询我的sqlite数据库以获取我的书表中的最后一个ID,然后插入最后一个ID+1的数据。我是Go的新手,我不知道如何设置我的lastidint变量。任何帮助将不胜感激。funcgetBookLastID(){varlastidinterr:=db.QueryRow("selectmax(id)frombooks").Scan(&lastid)fmt.Println(lastid)return(lastid+1)}funcinsertBook(name,authorstring,pagesint,publicationDatetime.Time)(int,error){//Crea

unit-testing - 无法在 golang : "unable to open database file [recovered]"-error 中打开 SQLite 数据库

我刚开始学习golang,不确定我的错误是概念上的还是语言上的。这很奇怪,因为只有在对我的代码进行单元测试时才会出现错误。如果我“去运行”一切正常。作为sqlite驱动程序,我使用mattn/go-sqlite3.这里是问题发生的地方:funcdbExec(command*string){db,err:=sql.Open("sqlite3",dbPath)//Pathanddriveraresetcorrecrtlydeferdb.Close()iferr!=nil{//Noproblemherepanic(err)}_,err=db.Exec(*command)iferr!=nil{

go - 在事务中创建一对一关联

用户服务.gofunc(serviceUserService)Create(model*models.User)(*models.User,error){db,err:=database.GetConnection()iferr!=nil{returnnil,err}tx:=db.Begin()iftx.Error!=nil{fmt.Errorf("%v",err)returnnil,err}iferr:=tx.Create(model).Error;err!=nil{fmt.Errorf("%v",err)tx.Rollback()returnnil,err}iferr:=tx.Sa

go - 使用事务进行 sqlite 查询?

我正在处理一项作业,该作业要求我们使用sqlite进行交易。这是我正在努力解决的部分:openthedatabaseandstartatransaction.Callthefunctiontoreadinallthezoneswiththattransaction,thencommitthetransactionwhenitreturns因为我只是查询数据库而不是插入/更新,所以我认为我不需要在设置事务方面做太多事情。这就是我正在使用的database,_:=sql.Open("sqlite3","./world.db")tx,_:=database.Begin()rows,err:=

html - 如何将 html 表单中的日期和时间输入类型存储到 sqlite3 DB 中

我正在个人助理应用程序中设置一个提醒功能。该应用程序接受提醒的详细信息作为html表单,其中还包括date和time输入字段。我正在使用golang创建我的服务器并使用它创建了一个sqlite数据库。但是表单中的日期和时间值不会保存在数据库中,而标题、描述等其他字段会被保存。我应该为sqlite数据库中的时间和日期字段使用什么数据类型?我试过使用TEXT作为日期和时间的数据类型,但它不起作用。输入形式:...DateTime...这是从表单生成的提醒对象:{title:"learngolang",description:"HowdoIsavedateandtimeindatabase?

go - 使用事务运行 Go 测试

我有使用FoundationDB的Go代码,我想测试它。我从字面上复制了GotestfromApple'sGithub.当我取消注释在事务中实际运行Set的行时,测试挂起然后超时。(该行仍然被注释掉,它按预期工作。)funcTestExampleTransactor(t*testing.T){fdb.MustAPIVersion(400)//Note:testbehavesthesamewithMustAPIVersion(600)db:=fdb.MustOpenDefault()setOne:=func(tfdb.Transactor,keyfdb.Key,value[]byte)e